草庐IT

C++11 auto 和 size_type

全部标签

c++ - 将 std::type_index 作为模板参数传递给函数模板

考虑以下代码(工作正常):namespacefruit{structapple{};}namespacelanguage{structenglish{};}typedefstd::pairmyPairType;std::unordered_mapmyMap={{"paul",{"likes",std::type_index(typeid(fruit::apple))}},{"jonas",{"likes",std::type_index(typeid(language::english))}}};现在我有以下功能模板:templatevoidGenerateProfile(void*d

炸裂!Windows XP 2024 版,界面与操作吊打 Win11

戳下方名片,关注并星标!回复“1024”获取2TB学习资源!👉体系化学习:运维工程师打怪升级进阶之路4.0—  特色专栏  —MySQL / PostgreSQL / MongoDBElasticSearch / Hadoop / RedisKubernetes / Docker / DevOpsKafka / RabbitMQ / Zookeeper 监控平台 / 应用与服务 / 集群管理Nginx / Git / Tools / OpenStack大家好,我是民工哥!1985年Windows操作系统问世,经过不断的更新与升级,它已经成为全球最流行的操作系统之一,这也算的上是一个伟大的创造发

c++ - 如何编写通用特征以将 T::value_type 与其他特征相匹配?

关闭。这个问题是notreproducibleorwascausedbytypos.它目前不接受答案。这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topic在这里,这个问题的解决方式不太可能帮助future的读者。关闭4年前。Improvethisquestion我正在尝试创建一种可以检测的“包装特征”,对于某些T和一些现有的一元特征Concept,即:T是“可迭代的”,并且T::value_type满足Concept这很有用,因为我有其他代码可能需要各种类型,包括std::vector,我想将此包装器特征用于enable_if所述代码中的各种功能。这是一个

c++ - 有没有办法将这个 "for i"c++ 预处理器宏转换为现代 C++ (11+)?

我正在寻找一种方法来用更现代的东西替换这个C++预处理器宏。#definefori(FORI_TYPE,FORI_FROM,FORI_TO)\for(FORI_TYPEi{FORI_FROM};\((FORI_FROM)(FORI_TO));\((FORI_FROM)理想情况下,我可以摆脱所有的?运算符(constexpr在这里有用吗?)并且“fori”不会像现在使用proceprocessor版本(对?运算符的评估)那样产生任何间接费用。此外,类型安全。使用示例:fori(size_t,0,n){cout 最佳答案 就其值(val

c++ - 我的 type_trait 在模板化/非模板化代码中的不同行为

在下面的代码片段中,has_bar在main和DoStuff方法中的行为不同:在main方法中,a_bar==false和b_bar==true。当我执行这个时,我得到2x“Foo”作为输出。为什么?#includestructA{voidFoo(){std::coutstructhas_bar:std::false_type{};templatestructhas_bar>:std::true_type{};templatevoidDoStuff(Tt){ifconstexpr(has_bar::value){t.Bar();}else{t.Foo();}}intmain(){Aa;

c++ - 在移出 vector 上调用 size() 方法是否安全?

这个问题在这里已经有了答案:Whatconstitutesavalidstatefora"movedfrom"objectinC++11?(2个答案)关闭3年前。标准指定STL容器在beginmoved之后(在这种情况下我们谈论启用move构造/赋值的std::move),在有效,但未指定状态。我相信这意味着我们只能应用不需要先决条件的操作。我记得这里有人在Stackoverflow上声称这是真的,经过一番检查后我同意了。不幸的是,我不记得我检查过哪些来源。此外,我无法在标准中找到相关信息。来自[container.requirements.general/4],table62([ta

c++ - 如何在 C++11 中返回包含自定义删除器的 std::unique_ptr?

我的应用程序编译器最多只能支持c++11。下面是我的项目和函数get_conn()的片段代码返回std::unique_ptr和自定义删除器(删除器需要两个参数)。我正在使用auto关键字作为返回类型,但它给出了一个错误,就像ifiscompiledwithc++11(compilesfinewithc++14)error:‘get_conn’functionuses‘auto’typespecifierwithouttrailingreturntype演示示例代码:#include#include#includeusingnamespacestd;//Dummydefinitiono

c++ - auto_ptr 会防止这种情况发生吗?

我不太清楚auto_ptr在这种情况下是否会帮助我:classA{A(constB&member):_member(B){};...constB&_member;};AgenerateA(){auto_ptrsmart(newB());AmyA(*smart);returnmyA;}当smart离开其封闭范围时,myA._member引用是否有效?如果auto_ptr不是这里的答案,那是什么?编辑:我看到我把每个人都弄糊涂了;我必须在范围外返回myA,这就是为什么我关心_member在smart退出范围后是否有效。 最佳答案 这对你

解决 “npm ERR! Node.js v20.11.0“ 错误的完整指南

npmERR!Node.jsv20.11.0完整指南概述在使用npm进行包管理和构建项目的过程中,有时会遇到错误信息“npmERR!Node.jsv20.11.0”,这个错误通常表示Node.js版本不兼容。本文将详细介绍如何解决这个问题,包括升级Node.js版本和验证版本兼容性等。步骤1:检查Node.js版本首先,您需要检查当前安装的Node.js版本。运行以下命令来查看您的Node.js版本:node-v这将输出您当前安装的Node.js版本号。如果版本号低于20.11.0,则需要升级Node.js。步骤2:升级Node.js要升级Node.js版本,有几种方法可供选择。在这里,我们将

C++ 编译错误枚举 "does not name a type"

以下代码:foo.h#include"bar.h"classfoo{public:enummy_enum_type{ONE,TWO,THREE};foo();~foo(){}};foo.cppfoo::foo(){inti=bar::MY_DEFINE;}酒吧.h#include"foo.h"classbar{public:staticconstintMY_DEFINE=10;foo::my_enum_typevar;bar(){};~bar(){};};让g++编译器提示my_enum_type“没有命名类型”。为什么?所有header都有多个包含定义(为清楚起见,此处未显示)。谢谢